We have examined the types of *operands* and *operations* that may be specified by *machine instructions*. Now we have to see how is the address of an operand specified, and how are the *bits* of an instruction organized to define the *operand addresses* and operation of that instruction.

### Addressing Modes:

The most common addressing techniques are:

- Immediate
- o **Direct**
- Indirect
- Register
- Register Indirect
- o Displacement
- Stack

### Two modes that need no address field at all :

### 1. Implied Mode

- No need to specify address in the instruction
- EA = AC, or EA = Stack[SP]
- Examples from Basic Computer CLA, CME



# - Address of the operands are specified implicitly in the definition of the instruction

### **2. Immediate Mode**

- Instead of specifying the address of the operand, operand is specified in the instruction itself.

- No need to specify address in the instruction
- However, operand itself needs to be specified
- Sometimes, require more bits than the address
- Fast to acquire an operand

**Immediate Addressing:** 

instruction:

This mode can be used to define and use constants or set initial values of variables. The advantage of immediate addressing is that no memory reference other than the instruction fetch is required to obtain the operand. The disadvantage is that the size of the number is restricted to the size of the address field, which, in most instruction sets, is small compared with the world length.

The simplest form of addressing is immediate addressing, in which the operand is actually present in the

### OPERAND = A



# Addressing Mode

### **<u>3. Register Mode</u>**

- When address field specifies a processor register, it is said to be in register mode
- Designated operand need to be in a register
- Shorter address than the memory address
- Saving address field in the instruction
- Faster to acquire an operand than the memory addressing
- EA = IR(R) (IR(R): Register field of IR)

**Register Addressing:** 

Register addressing is similar to direct addressing. The only difference is that the address field referes to a register rather than a main memory address:

is very limited.



### EA = R

The advantages of register addressing are that only a small address field is needed in the instruction and no memory reference is required. The disadvantage of register addressing is that the address space



### **4. Register Indirect Mode**

- Instruction specifies a register which contains the memory address of the operand
- Saving instruction bits since register address is shorter than the memory address
- Slower to acquire an operand than both the register addressing or memory
- Adv : Fewer address bit reqd. compared to memory address
- EA = [IR(R)]([x]: Content of x)

**Register Indirect Addressing:** 

Register indirect addressing is similar to indirect addressing, except that the address field refers to a register instead of a memory location. It requires only one memory reference and no special calculation.

EA = (R)

Register indirect addressing uses one less memory reference than indirect addressing. Because, the first information is available in a register which is nothing but a memory address. From that memory location, we use to get the data or information. In general, register access is much more faster than the memory access.

# addressing



# **5. Autoincrement or Autodecrement Mode**

# - Similar to Register Indirect but When the address in the register used to access memory, the value in the register is incremented or decremented by 1 automatically



### **<u>6. Direct Address Mode</u>**

operand

- Faster than the other memory addressing modes - Too many bits are needed to specify the address for a large physical memory space - EA = IR(addr) where (IR(addr): address field of IR)



- Instruction specifies the memory address which can be used directly to access the

### **Direct Addressing:**

A very simple form of addressing is direct addressing, in which the address field contains the effective address of the operand:

EA = A

It requires only one memory reference and no special calculation.



## 7. Indirect Addressing Mode

contains the address of the operand

- When the abbreviated address is used large physical memory can be addressed with a relatively small number of bits

- Slow to acquire an operand because of an additional memory access
- EA = M[IR(address)]

### - The address field of an instruction specifies the address of a memory location that



**Indirect Addressing:** 

With direct addressing, the length of the address field is usually less than the word length, thus limiting the address range. One solution is to have the address field refer to the address of a word in memory, which in turn contains a full-length address of the operand. This is know as indirect addressing:

EA = (A)



### **Diaplacement Addressing:**

A very powerful mode of addressing combines the capabilities of direct addressing and register indirect addressing, which is broadly categorized as displacement addressing:

EA = A + (R)

Displacement addressing requires that the instruction have two address fields, at least one of which is explicit. The value contained in one address field (value = A) is used directly. The other address field, or an implicit reference based on opcode, refers to a register whose contents are added to A to produce the effective address.

Three of the most common use of displacement addressing are:

- Relative addressing
- Base-register addressing
- Indexing



# Q1. Which addressing mode execute its instructions within CPU without the necessity of reference memory for operands?

- a. Indirect Mode
- b. Immediate Mode
- c. Direct Mode
- d. Register Mode



### 8. Relative Addressing Modes

the operand

- Address field of the instruction is short
- Large physical memory can be accessed with a small number of address bits - EA = f(IR(address), R), R is sometimes implied

### -3 different Relative Addressing Modes depending on R;

**PC Relative Addressing Mode (R = PC)** - EA = PC + IR(address) **Indexed Addressing Mode** (R = IX, where IX: Index Register) - EA = IX + IR(address) **Base Register Addressing Mode** - EA = BAR + IR(address)



- The Address fields of an instruction specifies the part of the address (abbreviated address) which can be used along with a designated register to calculate the address of

**Adv : Shorter Address Field** 

(R = BAR, where BAR: Base Address Register)

| Addressing<br>Mode      |     | Effective<br>Address          |     | Content<br>of AC |    |     |
|-------------------------|-----|-------------------------------|-----|------------------|----|-----|
| Direct address          | 500 | /* AC ← (500)                 | */  | 800              |    |     |
| <b>Immediate</b> operar | nd  | - → <b>AC</b> <sup>*</sup> /  | 500 |                  | */ | 500 |
| Indirect address        | 800 | /* AC ← ((500))               | */  | 300              |    |     |
| <b>Relative address</b> | 702 | /* AC ← (̀PC+5́00)            | */  | 325              |    |     |
| Indexed address         | 600 | /* AC ← (̈RX+500)́            | */  | 900              |    |     |
| Register                |     | -/* AC ← Ř1 ′                 | */  | 400              |    |     |
| Register indirect       | 400 | $/* AC \leftarrow (R1) */ 70$ | )0  |                  |    |     |
| Autodecrement           | 399 | /* AC ← -(R)                  | */  | 450              |    |     |
| Autoincrement           | 400 | /* AC ← (R1)+                 | */  | 700              |    |     |



| Addres | s Memory         |
|--------|------------------|
| 200    | Load to AC Mode  |
| 201    | Address = 500    |
| 202    | Next instruction |
|        |                  |
| 399    | 450              |
| 400    | 700              |
|        |                  |
| 500    | 800              |
|        |                  |
| 600    | 900              |
|        |                  |
| 702    | 325              |
|        |                  |
| 800    | 300              |

**Reduced Set Instruction Set Architecture (RISC) –** The main idea behind is to make hardware simpler by using an instruction set like a load command will load data, store command will store the data. **Complex Instruction Set Architecture (CISC)** – The main idea is that a single instruction will do all loading, evaluating and

storing operations just like a multiplication command will do stuff like loading data, evaluating and storing it, hence it's complex.

Both approaches try to increase the CPU performance

- **RISC:** Reduce the cycles per instruction at the cost of the number of instructions per program.
- **CISC:** The CISC approach attempts to minimize the number of instructions per program but at the cost of increase in number of cycles per instruction.

composed of a few basic steps for loading, evaluating and storing operations just



# Characteristic of RISC –

1.Simpler instruction, hence simple instruction decoding. 2.Instruction come under size of one word. 3.Instruction take single clock cycle to get executed. 4. More number of general purpose register. 5.Simple Addressing Modes. 6.Less Data types. 7.Pipeling can be achieved.

# Characteristic of CISC –

1.Complex instruction, hence complex instruction decoding. 2.Instruction are larger than one word size. memory itself. 5.Complex Addressing Modes. 6.More Data types.

- 3. Instruction may take more than single clock cycle to get executed.
- 4.Less number of general purpose register as operation get performed in



# **Example –** Suppose we have to add two 8-bit number:

- this like ADD which will perform the task.
- load data in registers then it will use suitable operator and then it will store result in desired location.

•CISC approach: There will be a single command or instruction for

•**RISC approach:** Here programmer will write first load command to

### Focus on software

Uses only Hardwired control unit

Transistors are used for more registers

Fixed sized instructions

Can perform only Register to Register Arth-

metic operations

Requires more number of registers

Code size is large

A instruction execute in single clock cycle

A instruction fit in one word

|          | CISC                                                     |
|----------|----------------------------------------------------------|
| F        | ocus on hardware                                         |
| U<br>gi  | ses both hardwired and micro pro-<br>rammed control unit |
| Tı<br>In | ransistors are used for storing complex                  |
| V        | ariable sized instructions                               |
| C<br>M   | an perform REG to REG or REG to MEM or<br>IEM to MEM     |
| R        | equires less number of registers                         |
| С        | ode size is small                                        |
| In       | nstruction take more than one clock cycle                |
| In       | nstruction are larger than size of one word              |

# Difference Between CISC and RISC

| Architectural<br>Characterstics | Complex Instruction Set Computer(CISC)                          | Reduced Instruction Set<br>Computer(RISC) |  |  |
|---------------------------------|-----------------------------------------------------------------|-------------------------------------------|--|--|
| Instruction size and            | Large set of instructions with variable formats (16-64 bits per | Small set of instructions with            |  |  |
| format                          | instruction).                                                   | fixed format (32 bit).                    |  |  |
| Data transfer                   | Memory to memory.                                               | Register to register.                     |  |  |
| CPU control                     | Most micro coded using control memory (ROM) but modern          | Mostly hardwired without control          |  |  |
|                                 | CISC use hardwired control.                                     | memory.                                   |  |  |
| Instruction type                | Not register based instructions.                                | Register based instructions.              |  |  |
| Memory access                   | More memory access.                                             | Less memory access.                       |  |  |
| Clocks                          | Includes multi-clocks.                                          | Includes single clock.                    |  |  |
| Instruction nature              | Instructions are complex                                        | Instructions are reduced and              |  |  |
|                                 | instructions are complex.                                       | simple.                                   |  |  |

| The       | CISC stands for |  |
|-----------|-----------------|--|
| a)        | Computer In     |  |
| b)        | Complete In     |  |
| <b>C)</b> | Computer Ir     |  |
| <b>d)</b> | Complex I       |  |

nstruction Set Compliment Instruction Set Compliment Indexed Set Components